21. (new) A method of mapping a plurality of virtual registers to a plurality of physical registers, the method comprising:

providing a plurality of virtual registers, wherein each of
the virtual registers comprises physical register
address bits; and providing a status indicator for
indicating a status of each of the virtual registers;
designating a subset of the virtual registers as virtual
local registers;

executing a save command, the executing of the save command comprising saving a mapping of all of the virtual local registers onto a stack; saving a status as indicated by the status indicator for each of the virtual local registers onto the stack, and setting the status of all of the virtual local registers to "clean";

executing a restore command, the executing the restore

command comprising popping the mapping of all of the

virtual local registers from the stack to the virtual

local registers; and popping the status of all of the

virtual local registers from the stack;

binding an argument, the argument binding comprising binding
a first virtual register of the virtual registers to a
second virtual register of the virtual registers; and
binding the status of the first virtual register to
the second virtual register;

| 27 | wherein the argument binding further comprises saving a |
|----|---------------------------------------------------------|
| 28 | mapping of the second virtual register onto the stack,  |
| 29 | saving the status of the second virtual register onto   |
| 30 | the stack, placing a physical address stored in the     |
| 31 | first virtual register in the second virtual register,  |
| 32 | and setting the status of the second virtual register   |
| 33 | to the status of the first virtual register; and        |
| 34 | wherein the argument binding occurs during a call       |
| 35 | instruction, wherein the call instruction has at least  |
| 36 | one argument, wherein the first virtual register is     |
| 37 | used for the at least one argument.                     |

|    | Senai No.: 09/825,/5:                                       |
|----|-------------------------------------------------------------|
| 1  | 22. (new) A method comprising:                              |
| 2  | decoding an instruction;                                    |
| 3  | if the instruction is a call instruction, then binding an   |
| 4  | argument of the call instruction;                           |
| 5  | wherein the argument binding comprises                      |
| 6  | copying a first virtual register of a plurality of          |
| 7  | virtual registers to a second virtual register of           |
| 8  | the virtual registers, each of the virtual                  |
| 9  | registers comprising physical register address              |
| 10 | bits, and                                                   |
| 11 | copying a first status indicator of a plurality of          |
| 12 | status indicators to a second status indicator of           |
| 13 | the status indicators, wherein each of the status           |
| 14 | indicators corresponds to a respective one of the           |
| 15 | virtual registers; and                                      |
| 16 | wherein the first virtual register is used for the argument |
| 17 | and the second virtual register is used as a formal         |
| 18 | parameter.                                                  |

23. (new) The method, as recited in claim 22, further comprising:

mapping a virtual register of the plurality of virtual registers from an old physical register to a new physical register, when the virtual register is a destination virtual register of an instruction being decoded; and

placing an address of the old physical register in an instruction retirement list related to the instruction being decoded if and only if the status indicator corresponding to the virtual register is not clean.

24. (new) The method, as recited in claim 23, further comprising:

saving the physical register address bits held in the second virtual register and the second status indicator to a stack and then setting to clean the second status indicator.

25. (new) The method, as recited in claim 23, further comprising:

setting the second status indicator to not clean when the second virtual register is mapped to a new physical register.

26. (new) The method, as recited in claim 22, wherein: a subset of the plurality of virtual registers are virtual local registers.

1

2

3

1

2

3

4

5

6

7

1

2

3

4

- 27. (new) The method, as recited in claim 26, further comprising:
  - executing a save command, the executing of the save command comprising saving the mapping of all of the virtual local registers onto a stack; and saving the status indicators corresponding to all of the virtual local registers onto the stack.
- 28. (new) The method, as recited in claim 27, wherein:
  the executing of the save command further comprises setting
  the status indicators corresponding to all of the
  virtual local registers to clean after the saving of
  the status indicators onto the stack.

The method, as recited in claim 28, further 29. (new) comprising:

1

2

3

4

5

6

7

8

1

2

3

4

1

2

3

4

5

6

executing a restore command, the executing the restore command comprising popping the mapping of all of the virtual local registers from the stack to the virtual local registers; and popping the status indicators corresponding to all of the virtual local registers from the stack.

30. (new) The method, as recited in claim 29, further comprising:

selectively executing the restore command if the instruction is a return instruction.

31. (new) The method, as recited in claim 22, wherein: following the argument binding, if the first virtual register is a destination register, the first virtual register is assigned a first physical register address which is different than a second physical register address stored in the second virtual register.

| Docket#:    | WDGNP001   |
|-------------|------------|
| Serial No.: | 09/825,753 |

1 32. (new) The method, as recited in claim 31, wherein:
2 before the assignment of the first physical register address
3 to the first virtual register, a corresponding first
4 physical register status is "free".

33. (new) The method, as recited in claim 32, wherein:

after the assignment of the first physical register address
to the first virtual register, the corresponding first
physical register status is "waiting".

1

2

3

| 1  | 34. (new) A processing device including:                    |
|----|-------------------------------------------------------------|
| 2  | . an instruction decoder adapted to decode an instruction;  |
| 3  | a plurality of physical registers;                          |
| 4  | a plurality of virtual registers, each of the virtual       |
| 5  | registers comprising physical register address bits;        |
| 6  | a plurality of status indicators, each of the status        |
| 7  | indicators corresponding to a respective one of the         |
| 8  | virtual registers;                                          |
| 9  | wherein if the instruction decoder decodes a call           |
| 10 | instruction, then binding an argument of the call           |
| 11 | instruction, the binding comprising                         |
| 12 | . copying a first one of the virtual registers into a       |
| 13 | second one of the virtual registers, and                    |
| 14 | copying a first one of the status indicators into a         |
| 15 | second one of the status indicators, the first              |
| 16 | status indicator corresponding to the first                 |
| 17 | virtual register and the second status indicator            |
| 18 | corresponding to the second virtual register; and           |
| 19 | wherein the first virtual register is used for the argument |
| 20 | and the second virtual register is used for a formal        |
| 21 | parameter.                                                  |

| 1  | 35. (new) The processing device, as recited in claim 34,     |
|----|--------------------------------------------------------------|
| 2  | wherein:                                                     |
| 3  | if the instruction decoder decodes an instruction having a   |
| 4  | destination virtual register selected from the virtual       |
| 5  | registers, then                                              |
| 6  | mapping the destination virtual register from an old $\cdot$ |
| 7  | physical register of the physical registers to a             |
| 8  | new physical register of the physical registers,             |
| 9  | and                                                          |
| 10 | placing an address of the old physical register in an        |
| 11 | instruction retirement list related to the                   |

placing an address of the old physical register in an instruction retirement list related to the instruction if and only if the status indicator corresponding to the destination virtual register is not clean.

36. (new) The processing device, as recited in claim 35, further including:

a stack; and

12

13

14

1

2

3

4

5

6

7

8

wherein if the instruction decoder decodes a call instruction, then saving the physical register address bits held in the second virtual register and the second status indicator to the stack and then setting to clean the second status indicator.

|   | Dockel#: WDGNARIT Serial No.: 09/825,753                     |
|---|--------------------------------------------------------------|
| 1 | 37. (new) The processing device, as recited in claim 35,     |
| 2 | wherein:                                                     |
| 3 | when the second virtual register is mapped to a new physical |
| 4 | register, setting the second status indicator to not         |
| 5 | clean.                                                       |
|   |                                                              |
|   |                                                              |
| 1 | 38. (new) The processing device, as recited in claim 34,     |
| 2 | wherein:                                                     |
| 3 | a subset of the plurality of virtual registers are virtual   |
| 4 | local registers.                                             |
|   |                                                              |
|   |                                                              |
| 1 | 39. (new) The processing device, as recited in claim 38,     |
| 2 | further including:                                           |
| 3 | a stack; and                                                 |
| 4 | wherein execution of a save command comprises saving the     |
| 5 | mapping of all of the virtual local registers onto the       |
| 6 | stack; and saving the status indicators corresponding        |
| 7 | to all of the wirtual local registers onto the stack         |

|   | Docket#: WDGNP001<br>Serial No.: 09/825,753                  |
|---|--------------------------------------------------------------|
| 1 | 40. (new) The processing device, as recited in claim 39,     |
| 2 | wherein:                                                     |
| 3 | the execution of the save command further comprises setting  |
| 4 | the status indicators corresponding to all of the            |
| 5 | virtual local registers to clean after the saving of         |
| 6 | the status indicators onto the stack.                        |
|   |                                                              |
|   |                                                              |
| 1 | 41. (new) The processing device, as recited in claim 40,     |
| 2 | wherein:                                                     |
| 3 | execution of a restore command comprises popping the mapping |
| 4 | of all of the virtual local registers from the stack         |
| 5 | to the virtual local registers; and popping the status       |
| 6 | indicators corresponding to all of the virtual local         |
| 7 | registers from the stack.                                    |
|   |                                                              |
|   |                                                              |
| 1 | 42. (new) The processing device, as recited in claim 41,     |
| 2 | wherein:                                                     |
| 3 | if the instruction decoder decodes a return instruction,     |
| 4 | then executing the restore command.                          |

43. (new) The processing device, as recited in claim 34, wherein:

following the argument binding, if the first virtual register is a destination register, the first virtual register is assigned a first physical register address which is different than a second physical register address stored in the second virtual register.

44. (new) A method comprising:

decoding an instruction;

maintaining a mapping of virtual registers to physical registers, a subset of the virtual registers being virtual local registers;

if the instruction is a save instruction, then executing a
 save command;

if the instruction is a restore instruction, then executing a restore command; and

wherein

1

2

3

4

5

6

7

1

2

3

5

6

7

8

9

10

11

12

13

14

15

16

the executing of the save command comprises saving the mapping of all of the virtual local registers onto a stack, and

the executing of the restore command comprises popping

the mapping of all of the virtual local registers

from the stack to the virtual local registers.

| 1 | 45. (new) The method, as recited in claim 44, wherein:     |
|---|------------------------------------------------------------|
| 2 | the executing of the save command further comprises saving |
| 3 | status indicators corresponding to all of the virtual      |
| 4 | local registers onto the stack, and                        |
| 5 | the executing of the restore command further comprises     |
| 6 | popping the status indicators corresponding to all of      |
| 7 | the virtual local registers from the stack.                |

46. (new) The method, as recited in claim 45, wherein:

the executing of the save command further comprises setting

the status indicators corresponding to all of the

virtual local registers to clean after the saving of

the status indicators corresponding to all of the

virtual local registers onto the stack.

1

2

3

4

5

| ì    | Sena 140.: U9/625,7                                      |
|------|----------------------------------------------------------|
| 1    | 47. (new) A processing device including:                 |
| 2    | an instruction decoder adapted to decode an instruction; |
| 3    | a plurality of physical registers;                       |
| 4    | a plurality of virtual registers, each of the virtual    |
| 5    | registers comprising physical register address bits,     |
| 6    | and a subset of the virtual registers being virtual      |
| 7    | local registers; and                                     |
| 8    | wherein                                                  |
| 9    | if the instruction decoder decodes a save instruction    |
| 10   | then executing a save command, the executing of          |
| l1 · | the save command comprising saving a mapping of          |
| 12   | all of the virtual local registers onto a stack,         |
| 13   | and                                                      |
| 14   | if the instruction decoder decodes a restore             |
| 15   | instruction, then executing a restore command,           |
| 16   | the executing of the restore command comprising          |
| 17   | popping the mapping of all of the virtual local          |
| 18   | registers from the stack to the virtual local            |
| 19   | registers.                                               |

- 48. (new) The processing device, as recited in claim 47, further including:
  - a plurality of status indicators, each of the status indicators corresponding to a respective one of the virtual registers; and

wherein

the executing of the save command further comprises
saving the status indicators corresponding to all
of the virtual local registers onto the stack,
and

the executing of the restore command further comprises popping the status indicators corresponding to all of the virtual local registers from the stack.

49. (new) The processing device, as recited in claim 48, wherein:

the executing of the save command further comprises setting
the status indicators corresponding to all of the
virtual local registers to clean after the saving of
the status indicators corresponding to all of the
virtual local registers onto the stack.

- a plurality of physical register status indicators, each of
  the physical register status indicators corresponding
  to a respective one of the physical registers; and
  wherein each of the physical register status indicators
  represents a selected one of a plurality of physical
  'register states, and the physical register states
  include "free", "waiting", and "valid".
- 1 51. (new) The processing device, as recited in claim 2 50, wherein:
  - physical registers available for mapping to virtual registers are represented as "free" in the corresponding physical register status indicators.
  - 52. (new) The processing device, as recited in claim 51, wherein:
    - physical register status indicators transition to

      representing "waiting" when the corresponding physical registers are mapped to virtual registers.

53. (new) The processing device, as recited in claim 2 52, wherein:

1

3

4

5

physical register status indicators transition to representing "valid" when the corresponding physical registers are written.